

#250  
60/19/01  
Docket No. 1075.1164

JC921 U.S. PRO  
09/834889  
04/16/01  


IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

In re Patent Application of: )  
Yosuke SENTA, et al. )  
Serial No.: To be assigned ) Group Art Unit: Unassigned  
Filed: April 16, 2001 ) Examiner: Unassigned  
For: CONTROL PROGRAM DEVELOPMENT )  
SUPPORT APPARATUS )

**SUBMISSION OF CERTIFIED COPY OF PRIOR FOREIGN**  
**APPLICATION IN ACCORDANCE**  
**WITH THE REQUIREMENTS OF 37 C.F.R. §1.55**

*Assistant Commissioner for Patents*  
Washington, D.C. 20231

*Sir:*

In accordance with the provisions of 37 C.F.R. §1.55, the applicant submits herewith a certified copy of the following foreign application:

Japanese Patent Application No. 2000-249521  
Filed: August 21, 2000.

It is respectfully requested that the applicant be given the benefit of the foreign filing date as evidenced by the certified papers attached hereto, in accordance with the requirements of 35 U.S.C. §119.

Respectfully submitted,  
STAAS & HALSEY LLP

By:

  
James D. Halsey, Jr.  
Registration No. 22,729

Date: April 16, 2001

700 11th Street, N.W., Ste. 500  
Washington, D.C. 20001  
(202) 434-1500

日本特許庁  
PATENT OFFICE  
JAPANESE GOVERNMENT

JC921 U.S. PRO  
09/834889  
04/16/01  


別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office.

出願年月日

Date of Application: 2000年 8月21日

出願番号

Application Number: 特願2000-249521

出願人

Applicant(s): 富士通株式会社

2001年 1月19日

特許庁長官  
Commissioner,  
Patent Office

及川耕造



出証番号 出証特2000-3113997

【書類名】 特許願

【整理番号】 0051086

【提出日】 平成12年 8月21日

【あて先】 特許庁長官殿

【国際特許分類】 G06F 17/50

【発明の名称】 制御プログラム開発支援装置

【請求項の数】 5

【発明者】

【住所又は居所】 神奈川県川崎市中原区上小田中4丁目1番1号 富士通  
株式会社内

【氏名】 千田 陽介

【発明者】

【住所又は居所】 神奈川県川崎市中原区上小田中4丁目1番1号 富士通  
株式会社内

【氏名】 佐藤 裕一

【特許出願人】

【識別番号】 000005223

【氏名又は名称】 富士通株式会社

【代理人】

【識別番号】 100092978

【弁理士】

【氏名又は名称】 真田 有

【電話番号】 0422-21-4222

【手数料の表示】

【予納台帳番号】 007696

【納付金額】 21,000円

【提出物件の目録】

【物件名】 明細書 1

【物件名】 図面 1

特2000-249521

【物件名】 要約書 1

【包括委任状番号】 9704824

【プルーフの要否】 要

【書類名】 明細書

【発明の名称】 制御プログラム開発支援装置

【特許請求の範囲】

【請求項1】 機構の動作を制御する制御プログラムを実行し、該機構に対する制御量を所定の制御周期で算出して出力する制御プログラム実行部と、

該機構を仮想的なモデルとして内部に構築され、該モデルを用い、前記所定制御周期よりも短く設定された所定のシミュレーション周期で、前記所定の制御周期に対応する時間に亘って該機構の動作をシミュレートすることにより、該機構の状態量を算出して出力するシミュレーション部と、

該制御プログラム実行部から該シミュレーション部への前記制御量、および、該シミュレーション部から該制御プログラム実行部への前記状態量を一時的に保持し中継する中継部と、

該シミュレーション部からの前記状態量が該中継部に保持されると、該シミュレーション部を、該制御プログラム実行部からの応答待ち状態へ移行させるとともに、該制御プログラム実行部による、前記状態量に応じた制御量の算出動作を開始させる一方、該制御プログラム実行部からの前記制御量が該中継部に保持されると、該制御プログラム実行部を、該シミュレーション部からの応答待ち状態へ移行させるとともに、該シミュレーション部による、前記制御量に応じたシミュレーション動作を開始させるシミュレーション制御部とをそなえたことを特徴とする、制御プログラム開発支援装置。

【請求項2】 サーボ機構の動作を制御する制御プログラムを実行し、該サーボ機構に対する制御量を所定の制御周期で算出して出力する制御プログラム実行部と、

該サーボ機構を仮想的なモデルとして内部に構築され、該モデルを用いて該サーボ機構の動作を動力学的に解析しながら、前記所定制御周期よりも短く設定された所定のシミュレーション周期で、前記所定の制御周期に対応する時間に亘って該サーボ機構の動作をシミュレートすることにより、該サーボ機構の状態量を算出して出力するシミュレーション部と、

該制御プログラム実行部から該シミュレーション部への前記制御量、および、

該シミュレーション部から該制御プログラム実行部への前記状態量を一時的に保持し中継する中継部と、

該シミュレーション部からの前記状態量が該中継部に保持されると、該シミュレーション部を、該制御プログラム実行部からの応答待ち状態へ移行させるとともに、該制御プログラム実行部による、前記状態量に応じた制御量の算出動作を開始させる一方、該制御プログラム実行部からの前記制御量が該中継部に保持されると、該制御プログラム実行部を、該シミュレーション部からの応答待ち状態へ移行させるとともに、該シミュレーション部による、前記制御量に応じたシミュレーション動作を開始させるシミュレーション制御部とをそなえたことを特徴とする、制御プログラム開発支援装置。

【請求項3】 該制御プログラム実行部が、一制御周期中において異なるタイミングで該シミュレーション部に入力されるべき複数の制御量を出力するものであり、

前記複数の制御量をそれぞれ所定のタイミングで該シミュレーション部に入力するように制御量の入力制御を行なうマルチレート制御手段をそなえたことを特徴とする、請求項2記載の制御プログラム開発支援装置。

【請求項4】 該シミュレーション制御部が、該シミュレーション部によるシミュレーション結果に基づいて、該制御プログラム実行部による前記制御量の算出動作の開始タイミングを決定することを特徴とする、請求項2記載の制御プログラム開発支援装置。

【請求項5】 該モデルが、その動作のシミュレーションを個別に実行することが可能な複数の部分から構成されるものであり、

該シミュレーション部が、前記複数の部分それぞれの動作を並列的にシミュレートする複数のプロセッサをそなえて構成されていることを特徴とする、請求項2記載の制御プログラム開発支援装置。

【発明の詳細な説明】

【0001】

【発明の属する技術分野】

本発明は、比較的小型で応答の速い製品について制御プログラムのサーボ制御

部分（サーボ制御プログラム）の開発を支援する技術に関するもので、例えば、磁気ディスクドライブ（HDD），光ディスクドライブ（CD，MO，DVD，MD），磁気テープ装置（DAT，VTR），NC工作機など、緻密なサーボ制御を必要とするあらゆる製品についてのサーボ制御プログラム（ファームウェア）を開発する際に用いて好適の、制御プログラム開発支援装置に関する。

## 【0002】

## 【従来の技術】

一般に、アクチュエータ（モータ）やセンサを有し3次元的な動作を行なう機構（メカ）を設計する際には、その機構の構想を練った後、詳細設計、出図、部品手配を行なってから、部品の組立を行なって実機を試作し、実機の動作等についての評価を行なう。そして、評価の結果に応じて設計変更を行なってから設計変更後の実機を試作し、再び評価を行なうという処理を繰り返し、評価の結果が良好であれば、設計を完了する。

## 【0003】

また、一般に、上述のごとく設計された機構を動作させるべく、その機構を制御するための制御プログラムを開発し、その制御プログラムを、制御対象の機構内に組み込まれるマイクロコンピュータ（以下、マイコンという場合がある）で実行させるようにしている。このマイコンが実行する上記制御プログラムのことを、以下、組込みソフトウェアという場合がある。

## 【0004】

上述のような制御プログラム（組込みソフトウェア）を開発する際、従来、制御すべき機構の試作品（実機）が完成している必要がある。即ち、試作が完了して初めてメカを具体的に動かすことができ、それを使って組込みソフトウェアの開発を開始することができるわけである。

## 【0005】

この組込みソフトウェアの開発は、試作品の完成後、その試作品を実際に動作させながら、以下の手順で行なわれる。つまり、まず、組込みソフトウェアの概略設計を行ない、その概略設計に基づいて詳細設計を行なってから、詳細設計の結果をコーディングして組込みソフトウェアを作成し、その組込みソフトウェア

のデバッグを行なう。

#### 【0006】

##### 【発明が解決しようとする課題】

ところで、ファームウェアのサーボ機構部分の構築・検証も、従来、上述した組込みソフトウェア開発の場合と同様、実際のメカ（実機）を用いて行なわれている。

しかし、ファームウェアのサーボ機構部分の構築・検証に上述の手法を用いた場合、実機が完成しないと検証を行なうことができず開発に時間やコストがかかり非効率的であるという課題があるほか、実機を用いて検証を行なうため、イベントブレイク等でファームウェアプログラムを停止しても、サーボ機構を成すモータは回転し続け、ステップデバッグを行なうことができないえないなどの課題もあった。

#### 【0007】

また、月産数万台も生産される製品に対するサーボ機構制御プログラムは、ある程度のメカのバラツキに対応できなくてはならない。実際のメカを用いた開発では、上記バラツキを考慮した所望の状態のメカを入手することは困難であり、ファームウェアがどの程度のバラツキまで対応できているかを知ることは困難であった。

#### 【0008】

そこで、実際のメカの代わりに計算機上に仮想的なモデルを作成し、このモデルを実際のファームウェアに制御させることにより、実機を用いることなく効率的にファームウェアの開発（構築・検証）を行なえるようにすることが望まれている。このような技術が実現されると、ファームウェアの先行開発が可能になるほか、実際のモータを用いないためステップデバッグなどの機能を使用することが可能であり、新しいアクチュエータやセンサを用いた新規の制御手法を、実機を作成することなく簡単に検証可能になるなどの利点が得られる。

#### 【0009】

従来、例えばdSPACE社のHIL（Hardware In the Loop）シミュレーションシステムのように、実際の製品の代わりとなるシミュレータ内のモデルに対

し、別のコンピュータで動作する制御プログラムによってそのモデルの制御を行なうものは存在している。しかし、このシステムは、実時間でシミュレーションを行なうものであるため、自動車や船など応答の遅い製品（例えば1 msec以上のシミュレーション時間間隔でシミュレーション可能な製品）がシミュレーション対象となっている。従って、上述のシステムにより、磁気ディスクドライブ（HDD）など比較的小型で応答の速い製品（例えば100  $\mu$ sec程度のシミュレーション時間間隔でシミュレーションを行なうべき製品）のシミュレーションを行なうのは困難である。

## 【0010】

また、本願発明者等は、3次元リアルタイムシミュレーション装置を中心核に据え、メカ試作品を作らなくても組込みソフトウェア（制御プログラム）の開発をメカ設計とは単独に進めることができるような支援システムを提案している。この支援システムによる制御プログラムの検証はタスクレベルで行なわれている。つまり、この支援システムでは、制御プログラム側からの指令に応じたアクチュエータ動作がシミュレートされ、その動作に従ったセンサのオン／オフ信号に基づいて、制御プログラムの検証が行なわれている。従って、この支援システムでは、モデルの動力学を解析するサーボレベルで制御プログラムの検証（開発・デバッグ）を行なうことができない。

## 【0011】

サーボ機構は、機械的運動のための自動フィードバック制御システムであり、制御量または制御出力が機械的な位置〔または誘導変数（速度加速度など）の一つ〕であるようなシステムを制御するために用いられるものである。このため、サーボ制御部分の制御プログラムの検証を行なうためには、サーボ機構のシミュレーションを、タスクレベルではなく、前記機械的な位置等の制御量を動力学的に解析しながら（つまりサーボレベルで）行なう必要がある。サーボレベルで検証を行なう場合、動力学解析を行なって厳密なシミュレーションを行なう必要があるため、実時間でシミュレーションを行なうことは困難になることがある。

## 【0012】

従って、実際のメカを用いることなく、比較的小型で応答の速い製品について

制御プログラムのサーボ制御部分（以下、サーボ制御プログラムという場合がある）の開発・デバッグ（検証）を行なえるようにすることが望まれている。

なお、従来、MATLABなどに代表される数値解析ソフトウェアを用いることにより、制御対象とその制御対象についての制御則とをモデル化し、その制御則の検証を行なう一般的な手法は存在している。この手法は、理論レベルで制御則の検証を行なうことはできるが、検証した制御則を実際のファームウェア（制御プログラム）にコード化する際に生じる様々な問題点（実行速度、コードサイズ、消費メモリ量、バグの混在など）には対応することができない。また、この手法は、制御則の検証を行なうものであって、その制御則に基づいて作成された制御プログラムの検証を行なうことはできず、その制御プログラムの検証に際しては、結局、前述した従来手法を用いることになる。

#### 【0013】

本発明は、このような課題に鑑み創案されたもので、実際のメカを用いることなく、比較的小型で応答の速い製品（機構）を制御するための制御プログラムの開発・デバッグ（検証）を行なえるようにした、制御プログラム開発支援装置を提供することを目的とする。

#### 【0014】

##### 【課題を解決するための手段】

上記目的を達成するために、本発明の制御プログラム開発支援装置（請求項1, 2）は、シミュレーション部での所定のシミュレーション周期が制御プログラム実行部での所定の制御周期よりも短く設定され、シミュレーション部が、前記所定の制御周期に対応する時間に亘って前記所定のシミュレーション周期で機構（サーボ機構）の動作をシミュレートし、そのシミュレーションによって得られた該機構の状態量を中継部へ出力するように構成されるとともに、シミュレーション制御部が、該シミュレーション部からの前記状態量が該中継部に保持されると、該シミュレーション部を、該制御プログラム実行部からの応答待ち状態へ移行させるとともに、該制御プログラム実行部による、前記状態量に応じた制御量の算出動作を開始させる一方、該制御プログラム実行部からの前記制御量が該中継部に保持されると、該制御プログラム実行部を、該シミュレーション部からの

応答待ち状態へ移行させるとともに、該シミュレーション部による、前記制御量に応じたシミュレーション動作を開始させることを特徴としている。

#### 【0015】

上述した本発明の制御プログラム開発支援装置では、制御対象プラントである機構（サーボ機構）がモデル化され、そのモデルの動作をシミュレートするためのシミュレーション部と、その機構（サーボ機構）の動作を制御するファームウェアを実行する制御プログラム実行部とが、中継部を介して接続される。そして、シミュレーション部の動作と制御プログラム実行部の動作とを、シミュレーション制御部によって同期させることができるので、時間厳密性を保ったまま精密なシミュレーションを行なうことが可能になる。その際、シミュレーション部が、制御プログラム実行部での制御周期（サーボ制御ファームウェアのサーボ周期）よりも短いシミュレーション周期でシミュレーションを行なうので、精密なシミュレーションを実行することが可能になる。

#### 【0016】

なお、該シミュレーション制御部（同期処理部）の同期設定を行なうための同期設定手段をさらにそなえ、その同期設定手段を、グラフィカルユーザインタフェース機能を用いて構成してもよい。これにより、シミュレーション部の動作と制御プログラム実行部の動作との同期設定を行なうことができ、さらに、グラフィックを用いて容易にその同期設定を行なうことができる。

#### 【0017】

また、該制御プログラム実行部が、一制御周期中において異なるタイミングで該シミュレーション部に入力されるべき複数の制御量を出力するように構成されるとともに、前記複数の制御量をそれぞれ所定のタイミングで該シミュレーション部に入力するように制御量の入力制御を行なうマルチレート制御手段がそなえられていてもよい（請求項2）。このとき、該マルチレート制御手段の設定を行なうためのマルチレート設定手段をそなえ、そのマルチレート設定手段を、グラフィカルユーザインタフェース機能を用いて構成してもよい。

#### 【0018】

上述したマルチレート制御手段を用いることにより、シミュレーション部は、

一制御周期中に制御量が変化するマルチレート制御をシミュレートすることができる。また、マルチレート設定手段により、そのマルチレート制御を定義・設定することができ、さらに、グラフィックを用いて容易にそのマルチレート制御の設定を行なうことができる。

## 【0019】

さらに、該シミュレーション制御部が、該シミュレーション部によるシミュレーション結果に基づいて、該制御プログラム実行部による前記制御量の算出動作の開始タイミングを決定してもよい（請求項3）。これにより、シミュレーション部によるシミュレーション結果に応じて、制御プログラム実行部でのサーボ制御ルーチンへ移行することができ、タイマによるフェイルセーフ機能を確認したり、単位時間当たりの変化量（速度、回転数等）を測定する処理などに対応したりすることができる。

## 【0020】

また、該モデルが、その動作のシミュレーションを個別に実行することが可能な複数の部分から構成されるものであり、該シミュレーション部が、前記複数の部分それぞれの動作を並列的にシミュレートする複数のプロセッサをそなえて構成されていてもよい（請求項4）。これにより、モデルの構成部分の動作シミュレーションを、複数のプロセッサで並列的に実行することができる。

## 【0021】

さらに、該中継部を、該制御プログラム実行部から該シミュレーション部への前記制御量と該シミュレーション部から該制御プログラム実行部への前記状態量とを含むデータを一時的に保持しうる複数のレジスタと、該複数のレジスタと該制御プログラム実行部との間で前記データの書込／読出を制御する第1書込／読出制御部と、該複数のレジスタと該シミュレーション部との間で前記データの書込／読出を制御する第2書込／読出制御部とによって構成してもよい（請求項5）。

## 【0022】

これにより、制御プログラム実行部からの制御量は、第1書込／読出制御部により適当なレジスタに一旦書き込まれた後、同期信号に応じ、第2書込／読出制

御部により読み出されてシミュレーション部に入力される。一方、シミュレーション部からの状態量は、第2書き込み／読み出し制御部により適当なレジスタに一旦書き込まれた後、同期信号（割込信号）に応じ、第1書き込み／読み出し制御部により読み出されて制御プログラム実行部に入力される。

## 【0023】

このとき、該制御プログラム実行部による前記制御量の算出動作を開始させるべく該シミュレーション部から該複数のレジスタの一つに入力された割込信号については、該第1書き込み／読み出し制御部を介することなく、当該レジスタから該制御プログラム実行部へ直接的に送出してもよい。これにより、制御プログラム実行部側では、第1書き込み／読み出し制御部による読み出制御（ファームウェアの読み込み動作）を行なうことなく割込信号（同期信号）を得ることができ、ハードウェア割り込みを利用した同期処理を行なうことが可能になる。

## 【0024】

また、該複数のレジスタに保持されているデータを表示しうるデータ表示部をそなえてもよい。このとき、該複数のレジスタの中から選択した少なくとも一つのレジスタに保持されているデータを該データ表示部に表示させる選択部をそなえてもよいし、該データ表示部を該複数のレジスタのうちの特定のものに直接的に接続し、このデータ表示部において、該特定のレジスタに保持されているデータを表示してもよい。これにより、制御プログラム実行部とシミュレーション部との間で通信中のデータがデータ表示部で表示され、オペレータ等はそのデータを参照・確認することができる。

## 【0025】

さらに、該複数のレジスタのうちの少なくとも一つに所望のデータを強制的に設定・格納するためのデータ入力部をそなえてもよい。このとき、該データ入力部を、該複数のレジスタのうちの特定のものに直接的に接続し、このデータ入力部から、該特定のレジスタに前記所望のデータを設定してもよい。これにより、オペレータ等は、任意のデータを、データ入力部からレジスタに書き込むことによって制御プログラム実行部やシミュレーション部へ直接的に入力することができ、そのデータに応じた制御プログラムの挙動やモデルの動作状態を確認するこ

とができる。

【0026】

またさらに、該複数のレジスタのうちの少なくとも一つから読み出されたデータにノイズを重畠するノイズ重畠部をそなえてもよい。これにより、オペレータ等は、ノイズをノイズ重畠部によってデータに重畠することができ、そのノイズに応じた制御プログラムの挙動やモデルの動作状態を確認することができる。

【0027】

【発明の実施の形態】

以下、図面を参照して本発明の実施の形態を説明する。

〔1〕本発明の一実施形態の説明

〔1-1〕本実施形態の全体構成

図1は本発明の一実施形態としての制御プログラム開発支援装置の構成を従来システムの構成と比較して示すもので、図1(a)は従来システムの構成を示すブロック図、図1(b)は本実施形態の構成を示すブロック図である。

【0028】

図1(a)に示すように、サーボ制御プログラムの開発・デバッグ(検証)を行なうための従来システムでは、実際のサーボ機構、つまり、実際のメカ100および制御回路200を用いている。

メカ100は、アクチュエータ110およびセンサ120を含んで構成されている。アクチュエータ110は、制御回路200からの制御量に従ってメカ100の動作を制御するものであり、センサ120は、アクチュエータ110で制御されるとともに外乱を受けるメカ100の動作状態を状態量として検出するものである。

【0029】

制御回路200は、制御用LSI210、ドライバ220および検出回路230をそなえて構成されている。

制御用LSI210は、サーボ機構の動作を制御する制御プログラム(制御プログラムのサーボ制御部分/ファームウェア)を実行するもので、MCU(MicroController Unit)211、メモリ212、サーボロジック213およびセンサ

ロジック214を有している。

【0030】

メモリ212は、前記制御プログラムを含む各種情報を格納するものであり、MCU211は、いわゆるワンチップマイコンであり、メモリ212に格納された制御プログラムを実行し、メカ100（サーボ機構）に対する制御量を、メカ100側からの状態量（センサ120による検出結果）に応じて演算するものである。

【0031】

サーボロジック213およびセンサロジック214は、それぞれ、ドライバ220および検出回路230に接続されるもので、例えばA/D（アナログ/デジタル変換器）、D/A（デジタル/アナログ変換器）、PIO（Parallel Input/Output）などの一般的なロジック回路を含んで構成されるものである。また、サーボロジック213としては、パルス幅変調（PWM）信号発生器を用いることもできる。

【0032】

ドライバ220は、サーボロジック213からの制御信号（制御量）に基づいてアクチュエータを駆動するものであり、検出回路230は、メカ100のセンサ120により検出された状態量を受け取り、センサロジック214に入力するものである。

なお、メカ100や制御回路200の状態は、オシロスコープ等の状態表示部300によって表示されるようになっている。

【0033】

上述した従来システムでは、実際のメカ100や制御回路200が用いられ、MCU211が、検出回路230およびセンサロジック214を介して得た情報（センサ120により検出された状態量）に基づいてサーボ演算を行ない、その演算結果である制御量を、制御信号としてサーボロジック213およびドライバ220を介しアクチュエータ110に指令を与えることで、サーボループが構築されている。

【0034】

これに対し、図1（b）に示すごとく、本実施形態の制御プログラム開発支援装置1は、制御回路10とモデル実行環境20とを、中継回路30を介して通信可能に接続することによって構成されており、制御回路10およびモデル実行環境20は、それぞれ、実際にはファームウェア実行用プロセッサおよびモデル演算用プロセッサにより構成されている。

## 【0035】

そして、制御回路10は、サーボ機構の動作を制御する制御プログラム（以下、制御ファームウェアという場合もある）を実行しそのサーボ機構に対する制御量を所定の制御周期（制御ルーチンの呼び出し間隔） $\Delta T$ で算出して出力する制御プログラム実行部として機能するもので、MCU12およびメモリ13を含む制御用LSI11から構成されている。

## 【0036】

ここで、メモリ13は、前記制御プログラムを含む各種情報を格納するものであり、MCU12は、いわゆるワンチップマイコンであり、メモリ13に格納された制御プログラムを実行し、サーボ機構（本実施形態では後述する仮想メカモデル21）に対する制御量を、モデル実行環境20側からの状態量（シミュレーション結果）に応じて演算するものである。

## 【0037】

モデル実行環境（以下、シミュレータという場合もある）20は、サーボ機構を仮想的なモデル（仮想メカモデル）21として内部に構築され、その仮想メカモデル21を用いてサーボ機構の動作を動力学的に解析しながら所定のシミュレーション周期 $\Delta t$ でサーボ機構の動作をシミュレートすることにより、サーボ機構の状態量を算出して出力するシミュレーション部として機能するものである。

## 【0038】

ここで、仮想メカモデル21は、図1（a）に示した従来システムにおけるサーボ機構の部分、即ち、サーボロジック213、ドライバ220、メカ100（アクチュエータ110およびセンサ120を含む）、検出回路230およびセンサロジック214の部分をモデル化したものである。

## 【0039】

中継回路（中継部）30は、制御回路10からモデル実行環境20への制御量、および、モデル実行環境20から制御回路10への状態量を中継すべく、これらの制御量や状態量を一時的に格納・保持する共有メモリ（バッファ、レジスタ）31を有して構成されている。この中継回路30の詳細構成については、図16～図20を参照しながら後述する。

状態表示記録部（データ表示部）40は、モデル実行環境20によるシミュレーション結果を表示したり記録したりするものである。

#### 【0040】

そして、本実施形態の制御プログラム開発支援装置1においては、シミュレーション周期 $\Delta t$ が制御周期 $\Delta T$ よりも短く設定され、モデル実行環境20は、所定の制御周期 $\Delta T$ に対応する時間に亘って所定のシミュレーション周期 $\Delta t$ でシミュレーションを行ない、そのシミュレーションによって得られたサーボ機構の状態量を中継回路30へ出力するように構成されている。

#### 【0041】

さらに、本実施形態の制御プログラム開発支援装置1には、後述するようにして制御回路10の動作とモデル実行環境20の動作との同期処理を行なうシミュレーション制御部（同期処理部）22がそなえられている。このシミュレーション制御部22は、図1（b）ではモデル実行環境20にそなえられているが、実際には、制御回路10およびモデル実行環境20にまたがる形で配置され、図2、図3および図5～図10にて後述する手法に従い、ソフトウェアにより実現されるものである。

#### 【0042】

このシミュレーション制御部22は、モデル実行環境20からの状態量が中継回路30の共有メモリ31に保持されると、モデル実行環境20を、制御回路10からの応答待ち状態へ移行させるとともに、制御回路10による、状態量に応じた制御量の算出動作を開始させる一方、制御回路10からの制御量が中継回路30に保持されると、制御回路10を、モデル実行環境20からの応答待ち状態へ移行させるとともに、モデル実行環境20による、制御量に応じたシミュレーション動作を開始させるように機能する。その際、図2や図3に示すごとく、制

御回路（制御ファームウェア）10とモデル実行環境（シミュレータ）20との間では、サーボ割込信号（S V I n t : Servo Interrupt）やサーボタスク信号（Servo Task）がやり取りされる。

#### 【0043】

図1（b）に示す本実施形態の制御プログラム開発支援装置1においては、MCU12、メモリ13など制御プログラムを動作させるために必要な環境（図1には示していないが浮動点演算装置などの補助回路も含む）以外の部分を全てモデル化し、モデル化された仮想メカモデル21の動作がモデル実行環境（シミュレータ）20によりシミュレートされ、仮想メカモデル21の状態量が算出される。そして、モデル実行環境20と制御回路10との間で、中継回路30の共有メモリ31を介して通信を行なうことにより、サーボループが構築されている。

#### 【0044】

このとき、対象とするメカの応答の高速化に伴いモデル実行（シミュレーション）のサンプリング間隔 $\Delta t$ を細かくする必要が生じたり、モデル21を精密化するのに伴い計算量が増大したりすると、シミュレータ20において、実時間でモデル演算を行なうことが難しくなる。

#### 【0045】

そこで、本実施形態の制御プログラム開発支援装置1においては、MCU12の演算を遅らせ、同期信号（サーボ割込信号）S V I n t を用いてMCU12の演算と仮想メカモデル21の演算とを同期させ、サーボ特性を変化させずにスローモーション的にシミュレーションを行なうようにしている。さらに、本実施形態では、サーボロジック213がマルチレート制御を実現していた場合の対応手法についても、図11～図13を参照しながら説明する。

#### 【0046】

##### 〔1-2〕 基本的な同期処理手順

次に、図2および図3を参照しながら、本実施形態における前記シミュレーション制御部（同期処理部）22の動作（同期処理手順）について説明する。図2および図3は、それぞれ、本実施形態での同期処理手順（シミュレーション制御部22の動作）を説明するためのフローチャートおよびタイムチャートである。

## 【0047】

図2に示す制御ファームウェア（制御F／Wの部分；制御回路10で実行される制御プログラム）は、サーボ制御ルーチン部分であって、一般にタイマ割り込みを用いて一定間隔（ $\Delta T$ ）で呼び出されたり、あるいは、制御対象が例えば磁気ディスクドライブ（HDD）である場合にはサーボマークを磁気ディスクから読み込んだ時に発生する割込信号によって呼び出されたりする。

## 【0048】

本実施形態の制御プログラム開発支援装置1では、サーボ制御ルーチンを呼び出すための割り込み要因を、シミュレータ20側からの割込信号（S V I n t）に変更し、シミュレータ20によるシミュレーション終了（所定間隔のモデル実行の完了）に伴って、サーボ制御ルーチンが呼び出されるようにしている。

## 【0049】

なお、割込信号を用いず、メインループにてシミュレータ20におけるS V I n tの状態を常に監視するように構成してもよい。これにより、図3を参照して後述するごとく、制御ルーチンとシミュレーションとを交互に実行することができる。

## 【0050】

図2に示すように、制御ファームウェア（制御回路10）においてはシミュレータ20からの割込信号（S V I n t）に応じてステップS11～S16の処理が実行され、シミュレータ20においては制御回路10からのサーボタスク信号に応じてステップS21～S27が実行される。これにより、本実施形態の同期処理（シミュレーション制御部22）が実現され、制御回路10の動作とシミュレータ20の動作との同期処理が行なわれる。

## 【0051】

具体的に説明すると、シミュレータ20において割込信号S V I n tがセットされると（ステップS21）、制御回路10では、制御ファームウェアが起動され、サーボタスク信号がセットされる（ステップS11）。

このサーボタスク信号は、シミュレータ20に通知され、シミュレータ20では、サーボタスク信号のセット検知に伴い（ステップS22のY E Sルート）、

割込信号 S V I n t をクリアする（ステップ S 2 3）。この後、シミュレータ 2 0 は、制御回路 1 0 からのサーボタスク信号がクリアされるまで、つまり、ステップ S 2 4 で Y E S 判定となるまで、制御ルーチン終了（サーボタスク信号クリア）待ち状態となる。

#### 【0052】

また、制御回路 1 0 では、割込信号 S V I n t のクリアを検知すると（ステップ S 1 2 の Y E S ルート）、中継回路 3 0 の共有メモリ（レジスタ）3 1 に保持されている状態量（シミュレータ 2 0 によるシミュレーション結果）が読み込まれ（ステップ S 1 3）、サーボ演算、つまり状態量に応じた制御量の演算処理が実行される（ステップ S 1 4）。そして、算出された制御量を中継回路 3 0 へ出力して共有メモリ 3 1 に格納してから（ステップ S 1 5）、サーボタスク信号をクリアし（ステップ S 1 6）、サーボ制御ルーチンを終了する。

#### 【0053】

一方、シミュレータ 2 0 では、サーボタスク信号のクリアを検知すると（ステップ S 2 4 の Y E S ルート）、中継回路 3 0 の共有メモリ（レジスタ）3 1 に保持されている制御量が読み込まれ（ステップ S 2 5）、シミュレーションが行なわれ（ステップ S 2 6）、その制御量に応じた仮想メカモデル 2 1 の状態量の演算処理が実行される。そして、シミュレーション結果として得られた状態量を中継回路 3 0 へ出力して共有メモリ 3 1 に格納すると（ステップ S 2 7）、再び、割込信号 S V I n t がセットされ（ステップ S 2 1）、以降、上述と同様の処理が繰り返されることになる。

#### 【0054】

図 2 にて上述した同期処理について図 3 を参照しながら説明する。図 3 に示すように、シミュレータ 2 0 は、時刻  $t_1$  で状態量を出力してシミュレーションを終了すると（ステップ S 2 7）、制御ルーチン終了（サーボタスク信号クリア）待ちの状態に移行するとともに、時刻  $t_2$  で割込信号 S V I n t をセットし（ステップ S 2 1）、制御ファームウェアを呼び出して起動する。

#### 【0055】

そして、時刻  $t_3$  において制御回路 1 0 がサーボタスク信号をセットすると（

ステップS11)、そのサーボタスク信号に応じ、時刻t4においてシミュレータ20が割込信号SVIntをクリアし(ステップS23)、制御ファームウェア(HDD F/W)は、時刻t5から制御ルーチン実行中となる(ステップS13~S15)。

#### 【0056】

この後、制御ファームウェアは、時刻t6で制御量を出力してサーボ演算を終了すると(ステップS15)、シミュレーション終了(SVIntセット)待ちの状態に移行するとともに、時刻t7でサーボタスク信号をクリアする(ステップS16)。これに伴い、シミュレータ20は、時刻t8からシミュレーション実行中となり(ステップS25~S27)、時刻t9で状態量を出力してシミュレーションを終了すると(ステップS27)、前述した処理を繰り返すことになる。

#### 【0057】

##### 〔1-3〕制御周期とシミュレーション周期との関係

さて、制御ルーチンが本来呼び出される間隔である制御周期を $\Delta T$ とすると、従来、シミュレータ20でのシミュレーション(モデル実行)も、制御周期と同じ間隔 $\Delta T$ で行なわれていた。しかし、精度のよいシミュレーションを行なうためや、後述するマルチレート制御などに対応するためには、シミュレーション間隔(シミュレーション周期) $\Delta t$ を、制御周期 $\Delta T$ よりも細かくする必要がある

。

#### 【0058】

そこで、本実施形態の制御プログラム開発支援装置1では、図2におけるシミュレーション実行部分(ステップS26)に際して、細かいシミュレーションサイクルを実行する毎に $\Delta t$ を加算し、その合計時間が制御周期 $\Delta T$ に達したところで、シミュレーションループから抜けるようにしている。

#### 【0059】

より具体的に説明すると、図4は本実施形態のシミュレータでのシミュレーション原理を説明するためのフローチャート(ステップS31~S34)であり、この図4に示すように、図2におけるシミュレーション実行部分(ステップS2

6) では、シミュレーションの開始に先立ち、合計時間  $t$  が 0 に設定される（ステップ S 3 1）。この後、シミュレータ 20 では、シミュレーション間隔  $\Delta t$  に対応する時間のシミュレーションが実行される都度（ステップ S 3 2）、合計時間  $t$  にシミュレーション周期  $\Delta t$  が加算され（ステップ S 3 3）、その合計時間が制御周期  $\Delta T$  に到達したか否かが判定される（ステップ S 3 4）。合計時間  $t$  が  $\Delta T$  未満である場合（ステップ S 3 4 の N O ルート）、ステップ S 3 2 に戻る一方、合計時間  $t$  が  $\Delta T$  以上となった場合（ステップ S 3 4 の Y E S ルート）、シミュレーションを終了する。

#### 【0060】

##### 〔1-4〕 基本的な同期設定

そして、本実施形態の制御プログラム開発支援装置 1 のシミュレータ 20 には、上述した周期  $\Delta T$  を設定するための機能〔シミュレーション制御部（同期処理部）22 の同期設定を行なうための同期設定手段〕がそなえられている。この機能は、シミュレータ 20 におけるグラフィカルユーザインタフェース機能（G U I 機能）を用いて実現されている。つまり、オペレータ等がシミュレータ 20 におけるディスプレイ（図示省略）上の表示を参照しながらキーボードやマウス等を操作することにより、周期  $\Delta T$  の設定（同期設定）が行なわれるようになっている。本実施形態では、一般的なモデル記述方法〔例えば M A T L A B / S i m u l i n k ( MathWorks 社 ) 〕を用いて、ディスプレイ上に図 5 に示すごとく簡易なモデル（ブロック線図）をグラフィカルに記述・作成することにより、同期設定が行なわれる。

#### 【0061】

ここで、図 5 は本実施形態で同期設定を行なうためのモデル記述レベル（ディスプレイでの表示状態）を示す図、図 6 は図 5 に示すモデル記述レベルで記述・設定された同期ブロック B 2 の動作を説明するためのフローチャートである。

本実施形態では、図 5 に示すモデル記述レベルで、一定周期  $\Delta T$  の方形波（パルス）を発生する方形波発生ブロック B 1 と同期ブロック B 2 とを作成し、方形波発生ブロック B 1 からのパルスを同期ブロック B 2 に入力するようにブロック B 1 および B 2 を記述する。

## 【0062】

同期ブロック（同期処理部、シミュレーション制御部22）B2は、方形波発生ブロックB1からのパルスのエッジ（立ち上がり）を検出し、そのエッジをトリガにして、制御ファームウェアとの同期処理を行なう。

この同期ブロックB2の動作を図6に示すフローチャート（ステップS41～S47）に従って具体的に説明する。なお、図6において、ステップS41およびS42はエッジ検出（パルス立ち上がり検出）を行なう部分である。また、ステップS44～S47は、制御ファームウェアとの同期を行なう部分で、図2のステップS21～S24に対応する処理である。

## 【0063】

同期ブロックB2は、シミュレーション周期 $\Delta t$ 毎に起動され、その都度、まず、同期ブロックB2に対する現入力（方形波発生ブロックB1からのパルス）が“High”であるか否かを判断する（ステップS41）。現入力が“High”でなければ、即ち“Low”である場合（ステップS41のNOルート）、現入力“Low”を前入力に置き換えて（ステップS43）、処理を終了する。

## 【0064】

一方、現入力が“High”である場合（ステップS41のYESルート）、前入力が“Low”であるか否かを判断し（ステップS42）、前入力が“Low”でなければ、即ち“High”である場合（ステップS42のNOルート）、現入力“High”を前入力に置き換えて（ステップS43）、処理を終了する。

そして、ステップS42で前入力が“Low”であると判断された場合（ステップS42のYESルート）、方形波発生ブロックB1からのパルスの立ち上がりエッジが検出されたことになる。この立ち上がりエッジの検出をトリガにして、制御ファームウェアとの同期処理（ステップS44～S47）へ移行する。

## 【0065】

この同期処理（ステップS44～S47）は、図2において説明したステップS21～S24の処理に対応するので、その説明は省略する。制御ファームウェアでサーボタスク信号がクリアされ、ステップS47でYES判定となると、同期処理を終了し、現入力“High”を前入力に置き換えて（ステップS43）、処

理を終了する。

【0066】

このとき、制御周期 $\Delta T$ とシミュレーション周期 $\Delta t$ を加算して得られる合計時間 $t$ （図4のステップS33参照）とには $\Delta t/2$ 未満の誤差を生じるが、制御周期 $\Delta T$ に対してシミュレーション周期 $\Delta t$ を任意に設定することができる。なお、制御周期 $\Delta T$ がシミュレーション周期 $\Delta t$ の自然数倍になつていれば前記誤差は0となるが、自然数倍になつていなければ、 $-\Delta t/2 \sim \Delta t/2$ の範囲の誤差が生じることになる。

【0067】

さらに、本実施形態の制御プログラム開発支援装置1では、シミュレーション制御部（同期処理部）22が、シミュレータ20によるシミュレーション結果に基づいて、制御回路10（制御ファームウェア）による制御量の算出動作の開始タイミングを決定するように構成することもできる。図5に示した方形波発生ブロックB1に代えて、例えば図7に示すようなサーボマーク50aの検出シミュレーション結果を同期ブロックB2に入力することにより、割込信号SVIDtが一定周期ではなく他の要因に応じて生成・出力されることになる。

【0068】

なお、図7に示す例では、HDDのディスク50におけるサーボマーク50aをヘッド51によって検出する状況がシミュレータ20によりシミュレートされている。このように生成された割込信号SVIDtの間隔を制御ファームウェア側で測定することにより、制御プログラム開発支援装置1は、速度（回転速度）を計測すべき処理に対応することができる。ただし、この場合、状態量の中に経過時間の情報を含ませる必要がある。

【0069】

また、本実施形態の制御プログラム開発支援装置1では、方形波発生ブロックB1から同期ブロックB2へ周期的に入力される方形波に対してわざと1パルス分の方形波を取り除く処理を加え、1パルス欠けた方形波を同期ブロックB2に入力することにより、制御ファームウェアでのタイマによるフェイルセーフ機能がきちんと作用するか否かの検証を行なうことができる。

## 【0070】

## 〔1-5〕入出力の同期設定

次に、図8～図10を参照しながら、本実施形態での入出力の同期設定について説明する。ここで、図8は本実施形態で入出力の同期設定を行なうためのモデル記述レベル（ディスプレイでの表示状態）を示す図、図9および図10は、それぞれ、図8に示すモデル記述レベルで記述・設定された同期ブロックB2'の動作を説明するためのフローチャートおよびタイムチャートである。

## 【0071】

図2に示す同期処理手順において、仮想メカモデル21は、シミュレーションを実行する前に制御回路10からの制御量を読み込み、シミュレーションを実行した後に状態量を出力しなければならない。本実施形態では、このような入出力の同期タイミングも、一般的なモデル記述方法〔例えばMATLAB/Simulink(MathWorks社)〕を用いて、ディスプレイ上に図8に示すごとく簡易なモデル（ブロック線図）をグラフィカルに記述・作成することによって設定される。

## 【0072】

図8に示すモデル記述レベルにおける同期ブロックB2'の出力は、この同期ブロックB2'への入力パルスの立ち上がりエッジに反応し、1シミュレーションサイクル( $\Delta t$ )分だけ“High”になる。そして、本実施形態では、図8に示すごとく、同期ブロックB2'の出力が“High”になる時をトリガとして制御対象モデルB5（シミュレータ20）から状態量を出力するように出力ブロックB4が記述・作成される一方、同期ブロックB2'の出力が“Low”になる時をトリガとして制御対象モデルB5（シミュレータ20）に制御量を入力するように入力ブロックB3が記述・作成されて、入出力タイミングが規定される。

## 【0073】

前述した同期ブロックB2'の動作を図9に示すフローチャート（ステップS51～S60）に従って具体的に説明する。なお、図9におけるステップS52およびS53は、図6のステップS41およびS42と同様、エッジ検出（パルス立ち上がり検出）を行なう部分である。また、ステップS57～S60は、制御ファームウェアとの同期を行なう部分で、図2のステップS21～S24に対

応する処理である。

## 【0074】

同期ブロック（同期処理部、シミュレーション制御部22）B2'は、シミュレーション周期 $\Delta t$ 毎に起動され、その都度、まず、同期ブロックB2'からの前出力が“High”であるか否かを判断する（ステップS51）。前出力が“High”でなければ、即ち“Low”である場合（ステップS51のNOルート）、同期ブロックB2'に対する現入力が“High”であるか否かを判断する（ステップS52）。現入力が“High”でなければ、即ち“Low”である場合（ステップS52のNOルート）、同期ブロックB2'からの出力を“Low”としてから（ステップS54）、現入力を前入力に置き換え且つ現出力を前出力に置き換えて（ステップS56）、処理を終了する。

## 【0075】

現入力が“High”である場合（ステップS52のYESルート）、前入力が“Low”であるか否かを判断し（ステップS53）、前入力が“Low”でなければ、即ち“High”である場合（ステップS53のNOルート）、前述したステップS54およびステップS56を実行して処理を終了する。

## 【0076】

そして、ステップS53で前入力が“Low”であると判断された場合（ステップS53のYESルート）、同期ブロックB2'への入力パルスの立ち上がりエッジが検出されることになる。この立ち上がりエッジの検出をトリガにして、同期ブロックB2'からの出力を“High”としてから（ステップS55）、現入力を前入力に置き換え且つ現出力を前出力に置き換えて（ステップS56）、処理を終了する。

## 【0077】

一方、ステップS51で前出力が“High”であると判断された場合（ステップS51のYESルート）、制御ファームウェアとの同期処理（ステップS57～S60）へ移行する。この同期処理（ステップS57～S60）は、図2において説明したステップS21～S24の処理に対応するので、その説明は省略する。制御ファームウェアでサーボタスク信号がクリアされ、ステップS60でYE

S判定となると、同期処理を終了し、ステップS52へ移行する。

【0078】

図9にて上述した同期ステップB2'の処理について図10を参照しながら説明する。図10におけるシミュレーション時刻t11～t12およびt13～t14に示すように、同期ブロックB2'の出力は、この同期ブロックB2'への入力パルスの立ち上がりエッジに反応して（ステップS53のYESルート）、制御周期（サーボ間隔） $\Delta T$ ごとに、1シミュレーション周期（シミュレーション間隔） $\Delta t$ の間だけ“High”になり（ステップS55）、それ以外の時には、同期ブロックB2'の出力は常に“Low”になる（ステップS54）。

【0079】

また、同期ブロックB2'の前出力が“High”であることをトリガとして（つまり同期ブロックB2'の出力パルスが立ち下がる直前）、シミュレータ20は、ステップS57～S60による同期処理へ移行してサーボタスク信号のクリア待ち状態になり、図10のシミュレーション時刻t12, t14でシミュレーションを停止した状態になる。サーボタスク信号がクリアされると（ステップS60のYESルート）、シミュレータ20によるシミュレーションが再開される。

【0080】

そして、同期ブロックB2'の出力パルスの立ち下がりに応じて入力ブロックB3が機能し、制御ファームウェアからの制御量が制御対象モデルB5（仮想メカモデル21）に入力される。また、同期ブロックB2'の出力パルスの立ち上がりに応じて出力ブロックB4が機能し、制御対象モデルB5（仮想メカモデル21）の状態量が出力される。

【0081】

〔1-6〕マルチレート制御への対応手法

次に、図11～図14を参照しながら、本実施形態の制御プログラム開発支援装置1での、マルチレート制御への対応手法について説明する。ここで、図11は本実施形態でのマルチレート制御について説明するための図、図12は本実施形態でマルチレート設定を行なうためのモデル記述レベル（ディスプレイでの表示状態）を示す図、図13は本実施形態でのマルチレート制御に先立つ初期設定

手順を説明するためのフローチャート、図14は、本実施形態でのマルチレート制御手順（図12に示すモデル記述レベルで設定されたマルチレートブロックB6の動作）を説明するためのフローチャートである。

【0082】

制御ファームウェア（F/W）は、サーボ制御ルーチンで計算した制御量を直ちにアクチュエータに出力せず、適当な回路を用いて一定時間が経過した後に出力することもある。例えば図11に示すように、サーボ制御ルーチン（一制御周期）の間に、アクチュエータに対する出力値（制御量）を“A”から“B”に変化させる制御を行なう場合がある。このような制御はマルチレート制御と呼ばれるもので、マルチレート制御を採用することにより、制御回路10（サーボ制御プログラム、制御ファームウェア）は、一制御周期中において異なるタイミングでシミュレータ20（仮想メカモデル21）に対して複数の制御量を出力することができる。

【0083】

本実施形態の制御プログラム開発支援装置1は、サーボ制御プログラムが上述のようなマルチレート制御を採用している場合にも対応することができるようになっている。そのため、制御プログラム開発支援装置1のシミュレータ20には、制御回路10からの複数の制御量をそれぞれ所定のタイミングで仮想メカモデル21（制御対象モデルB5）に入力するように制御量の入力制御を行なうマルチレート制御手段がそなえられる。このマルチレート制御手段は、図12に示すごとく記述・設定されるマルチレートブロックB6によって実現される。

【0084】

本実施形態の装置1をマルチレート制御に対応させるためには、図11および図12に示すごとく、ファームウェアから制御量（例えばA、B）とともにその制御量を出力するまでの時間（例えばT<sub>a</sub>、T<sub>b</sub>）を入力する。なお、その時間が固定されている場合には、仮想メカモデル21の中でその時間を指定してもよい。

【0085】

そして、本実施形態の制御プログラム開発支援装置1のシミュレータ20には

、上述したマルチレート制御手段を設定するための機能（マルチレート設定手段）がそなえられている。この機能は、シミュレータ20におけるグラフィカルユーザインターフェース機能（GUI機能）を用いて実現されている。つまり、オペレータ等がシミュレータ20におけるディスプレイ（図示省略）上の表示を参照しながらキーボードやマウス等を操作することにより、マルチレート制御手段の設定が行なわれるようになっている。本実施形態では、一般的なモデル記述方法〔例えばMATLAB/Simulink（MathWorks社）〕を用いて、ディスプレイ上に図12に示すごとく簡易なモデル（ブロック線図）をグラフィカルに記述・作成することにより、マルチレート制御手段の設定が行なわれる。

#### 【0086】

図12に示す例では、図8に示したものと同様の同期ブロックB2'のほか、入力ブロックB3、制御対象モデルB5、マルチレートブロックB6および遅延ブロック（1/Z）B7が記述されている。ここで、同期ブロックB2'の出力は、入力ブロックB3に入力されるとともに、遅延ブロックB7を介してマルチレートブロックB6に入力されている。

#### 【0087】

また、入力ブロックB3と制御対象モデルB5との間にマルチレートブロックB6が記述され、入力ブロックB3からのマルチレート制御にかかる制御量A、Bは、それぞれの出力タイミング（時間Ta、Tb）とともにマルチレートブロックB6に入力され、このマルチレートブロックB6から所定の出力タイミングで制御対象モデルB5に入力されるようになっている。マルチレート制御以外の制御量は、入力ブロックB3から制御対象モデルB5へ直接的に入力されるようになっている。

#### 【0088】

なお、図12において、1/Zの遅延ブロックB7が記述されているのは、同期ブロックB2'からの制御パルス（出力パルス）を、1シミュレーションサイクル△tだけ遅延させるためである。つまり、マルチレートブロックB6に入力される制御パルスは、遅延ブロックB7により、入力ブロックB3に入力される制御パルスよりも1シミュレーションサイクル△tだけ遅くなる。入力ブロック

B 3 およびマルチレートブロック B 6 は、いずれも、同期ブロック B 2' からの制御パルスの立ち下がりエッジをトリガとして起動される。

## 【0089】

上述のような遅延処理を行なうことで、必ず、入力ブロック B 3 による処理が実行されてから、マルチレートブロック B 6 による処理が実行されることになる。つまり、制御回路 10 (ファームウェア) からの指令 (制御量、時間) を入力ブロック B 3 で確実に受け取った後に、マルチレートブロック B 6 がマルチレート制御を実行することになる。

## 【0090】

このとき、厳密に言えば、マルチレートブロック B 6 に  $1/Z$  だけ遅れた制御パルスを与えると、マルチレート制御は  $\Delta t$  だけ遅延することになるが、制御周期  $\Delta T$  に対してシミュレーション周期  $\Delta t$  は小さいので、上述のような  $\Delta t$  の遅延は無視することができる。ただし、厳密性を確保したい場合や制御周期  $\Delta T$  に対してシミュレーション周期  $\Delta t$  が小さくない場合などには、マルチレートブロック B 6 において、時間  $T_a$  や  $T_b$  から  $\Delta t$  を減算して用いればよい。

## 【0091】

なお、図 12 では、遅延ブロック B 7 をマルチレートブロック B 6 と別個に記述しているが、マルチレートブロック B 6 の内部で、遅延ブロック B 7 と同様の処理を行なってもよく、その場合、遅延ブロック B 7 の記述を省略することができる。また、ここでは、2 段のマルチレート制御 (制御量 A, B) について説明しているが、本発明は、この段数に限定されるものではなく、同様の原理で 3 段以上のマルチレート制御にも適用される。

## 【0092】

ついで、前述したマルチレートブロック B 6 の動作を、図 14 に示すフローチャート (ステップ S 71 ~ S 93) に従って具体的に説明する。

なお、マルチレート制御に先立って初期設定処理が実行されるので、まず、この初期設定処理の手順を、図 13 に示すフローチャート (ステップ S 61 ~ S 64) に従って説明する。つまり、シミュレータ 20 においては、データ用メモリを確保し (\*p=new Data; ステップ S 61) 、初期出力値 (p->v=0) を設定する

とともに（ステップS62）、初期出力時間（p->t=0）を設定し（ステップS63）、さらに、リスト構造用初期値（p->next=NULL）を設定する（ステップS64）。

## 【0093】

さて、図14を参照しながら、マルチレートブロックB6の動作について説明する。

図13や図14において、“->”は、C言語やC++言語の構造体もしくはクラスメンバにアクセスするための演算子を示すものである。

また、構造体もしくはクラスデータは、制御量“v”と、その制御量を出力する時間“t”と、さらに次のデータへのポインタ“next”という3つのメンバを有している。

## 【0094】

さらに、変数“p”は、次のような状態（データの型）で保存されている。

p->v : p->t 時の出力（制御量）

p->t : p->v を出力する時間

p->next : 次のポインタ p->next->v

                  p->next->t

                  p->next->next : p->next->next->v

                  p->next->next->t

                  p->next->next->next : .....

## 【0095】

このようにして、メンバ“next”を用いてリスト構造が形成され、t, vの組がいくつでも記憶される。“next”として“NULL”を設定されたデータが、リスト構造の最後（末端）のデータである。

以下では、例えば、 $\Delta t = 1$  とし、且つ、以下のようなリスト構造のデータが設定されている場合についての、マルチレートブロックB6の動作を図14に従って説明する。

## 【0096】

p->v =-1

$p \rightarrow t = -1$

$p \rightarrow \text{next} = P1$

$P1 \rightarrow v = 2$  (=  $p \rightarrow \text{next} \rightarrow v$ )

$P1 \rightarrow t = 1$

$P1 \rightarrow \text{next} = P2$

$P2 \rightarrow v = 4$  (=  $P1 \rightarrow \text{next} \rightarrow v = p \rightarrow \text{next} \rightarrow \text{next} \rightarrow v$ )

$P2 \rightarrow t = 3$

$P2 \rightarrow \text{next} = \text{NULL}$

#### 【0097】

図14に示すシミュレーションサブルーチンは、シミュレーション周期 $\Delta t$ 毎に呼び出されて実行され、まず、トリガ（遅延ブロックB7からの制御パルスの立ち下がりエッジ）が検出されたか否かを判断する（ステップS71）。

トリガが検出されない場合（ステップS71のNOルート）、下記(1)～(4)の処理が順次実行されることになる。

#### 【0098】

(1)  $q \leftarrow p$ ,  $q \rightarrow t$  (=  $p \rightarrow t$ )  $\leftarrow -2$

(2)  $q \leftarrow q \rightarrow \text{next}$  (=  $P1$ ),  $q \rightarrow t$  (=  $P1 \rightarrow t$ )  $\leftarrow 0$

(3)  $q \leftarrow q \rightarrow \text{next}$  (=  $P2$ ),  $q \rightarrow t$  (=  $P2 \rightarrow t$ )  $\leftarrow 2$

(4)  $q \leftarrow q \rightarrow \text{next}$  (=  $\text{NULL}$ ),  $q$  は  $\text{NULL}$  だからループを抜ける。

#### 【0099】

ここで、(1)は、ステップS72の後、ステップS73のNOルートからステップS74に移行した結果であり、(2)および(3)は、いずれも、ステップS75の後、ステップS73のNOルートからステップS74に移行した結果であり、(4)は、ステップS75の後、ステップS73のYESルートを通って、ステップS73～S75のループを抜けることを示している。

#### 【0100】

そして、“ $p \rightarrow \text{next}$ ”は“ $P1$ ”であって“ $\text{NULL}$ ”ではなく（ステップS76の

NOルート)、且つ、“p->next->t”は“0”であって“0”以上であるので(ステップS77のYESルート)、出力値(マルチレートブロックB6から出力される制御量)“p->v”として“-1”を出力し(ステップS81)、処理を終了する。この時点でのデータをまとめると、

【0101】

p->v =-1

p->t =-2

p->next =P1

P1->v=2 (=p->next->v)

P1->t=0

P1->next = P2

P2->v=4 (= P1->next->v = p->next->next->v)

P2->t=2

P2->next = NULL

となる。

【0102】

この後、シミュレーション周期 $\Delta t$ が経過し、シミュレーションサブルーチンが呼び出されて実行され、再び、トリガが検出されない場合(ステップS71のNOルート)、ステップS72～S75の処理により、データは、

p->v =-1

p->t =-3

p->next =P1

P1->v=2 (=p->next->v)

P1->t=-1

P1->next = P2

P2->v=4 (= P1->next->v = p->next->next->v)

P2->t=1

P2->next = NULL

となる。この後、処理は、ステップS73のYESルートを通って、ステップS73～S75のループを抜けることになる。

#### 【0103】

このとき、“p->next”は“P1”であって“NULL”ではなく（ステップS76のNOルート）、“p->next->t”が“-1”で“0”未満であるので（ステップS77のNOルート）、下記(5)～(7)の処理が、それぞれ、ステップS78～S80により、順次実行されることになる。

#### 【0104】

(5) q=p->next (=P1)

(6) delete p (領域 p を解放)

(7) p=q (=P1)

これに応じて、データは、

p->v =2 (=P1)

p->t =-1

p->next =P2

P2->v=4 (=p->next->v)

P2->t=1

P2->next = NULL

となり、“p->next”は“P2”であって“NULL”ではなく（ステップS76のNOルート）、且つ、“p->next->t”は“1”であって“0”以上であるので（ステップS77のYESルート）、出力値（マルチレートブロックB6から出力される制御量）“p->v”として“2”を出力し（ステップS81）、処理を終了する。

#### 【0105】

上述のようにして、出力値“p->v”は所定のタイミングで“-1”から“2”

に変更される。また、処理に伴い “p->next” が “NULL” となった場合（ステップS76のYESルート）には、出力値として “p->v” を出力し続けることになる。

#### 【0106】

一方、トリガが検出された場合（ステップS71のYESルート）、そのトリガに伴って、入力ブロックB3から新規（未処理）のマルチレートデータが入力されることがあるので、未処理の入力（マルチレートデータ）が存在するか否かを判断する（ステップS82）。

#### 【0107】

未処理の入力がない場合（ステップS82のNOルート）には、ステップS72に移行して前述した処理を行なう。これに対し、未処理の入力がある場合（ステップS82のYESルート）には、ステップS83～S93の処理を実行することにより、未処理のマルチレートデータを、既に時系列順に保持されているマルチレートデータ列中の適当な位置に配置し、未処理のマルチレートデータを含めたマルチレートデータ列を時系列順に保持する。

#### 【0108】

次に、上述したデータ状態に引き続いでもトリガが検出され（ステップS71のYESルート）、且つ、未処理の入力（例えばv=3,t=3）があった場合（ステップS82のYESルート）について説明する。このとき、下記(8)～(13)の処理が順次実行される。

#### 【0109】

(8) まず領域を確保し、そのポインタを “tmp” とする（仮にtmp=P3とする；ステップS83）。

(9) “tmp->v=3” , “tmp->t=3” , “tmp->next=NULL” を入力値として設定する（ステップS84）。

(10) “p->t(=-1)” よりも “tmp->t (=3)” が大きいので（ステップS85のNOルート）、

#### 【0110】

(11) “q = p” により、“q” として “P1” が設定される（ステップS86）。

(12) “`q->next (=P2)`” は存在し (ステップ S 8 7 の N〇ルート) 、且つ、“`q->next->t (=P2->t =1)`” は “`tmp->t (=3)`” よりも小さいので (ステップ S 8 8 の N〇ルート) 、“`q`” は “`q->next (=P2)`” に設定され (ステップ S 8 9) 、ステップ S 8 7 に戻る。

## 【0 1 1 1】

(13) そして、今度は `q->next (=P2->next =NULL)` がは存在しないので (ステップ S 8 7 の YES ルート) 、“`tmp->next`” として “`q->next (=NULL)`” を設定するとともに (ステップ S 9 0) 、“`q->next`” として “`tmp (=P3)`” を設定してから (ステップ S 9 1) 、ステップ S 8 2 に戻る。この後、本例では、未処理の入力はないので (ステップ S 8 2 の N〇ルート) 、ステップ S 7 2 に移行する。

## 【0 1 1 2】

以上の処理により、データは、

`p->v =2` (=P1)

`p->t =-1`

`p->next =P2`

`P2->v=4` (=`p->next->v`)

`P2->t=1`

`P2->next = P3`

`P3->v=3` (= `P2->next->v = p->next->next->v`)

`P3->t=3`

`P3->next = NULL`

に更新される。

## 【0 1 1 3】

なお、ステップ S 8 5 で “`p->t`” よりも “`tmp->t`” が小さいと判断された場合 (ステップ S 8 5 の YES ルート) には、“`tmp->next`” として “`p`” を設定するとともに (ステップ S 9 2) 、“`p`” として “`tmp`” を設定してから (ステップ

S 9 3 ) 、ステップ S 8 2 に戻る。

以上のようにして、トリガが検出された場合、新規（未処理）の入力のすべてに対し、時間  $t$  の大きさを比較し、“ $t$ ”の小さい順（昇順）に入力（マルチレートデータ）を並べる処理が行なわれる。

#### 【0114】

##### 【1-7】シミュレーションの並列処理

仮想メカモデル21が、その動作のシミュレーションを個別に実行することができる複数の部分から構成されるものである場合、本実施形態におけるモデル実行環境（シミュレータ）20を、前記複数の部分それぞれの動作を並列的にシミュレートする複数のプロセッサ（図15のMCU12a～12c参照）によって構成することで、シミュレーション処理の高速化をはかることができる。

#### 【0115】

例えば制御対象（仮想メカモデル21）がHDDである場合、本実施形態におけるモデル実行環境（シミュレータ）20においては、図15に示すように、仮想メカモデル21をディスクモデル、アームモデル、流体モデルのような相関関係の低い3つの部分に分割し、各部分の動作を個別のプロセッサ（例えばMCU12a, 12b, 12c）により並列的に解析してシミュレートすることができる。これにより、シミュレーション処理を大幅に高速化することができる。なお、図15は本実施形態でのシミュレーションの並列処理を説明するための図である。

#### 【0116】

この場合、これらのMCU12a～12cのうちの一つがマスタとなり、他のスレーブMCUは、マスタが発生する信号に対し割込やポーリングを行なうことによって、これらのMCU12a～12cのシミュレーション時間を同期させることができる。また、同期をとる間隔は、アームとディスクのように相関関係が低いモデルどうしについてはサーボ間隔（制御周期 $\Delta T$ ）とし、また流体が絡むなど、多少の相関関係があるモデルどうしについてはシミュレーション間隔（シミュレーション周期 $\Delta t$ ）とする。

#### 【0117】

## 〔1-8〕中継回路の詳細構成および各種機能

図16は本実施形態の中継回路30の構成および割込信号S V I n tの取扱を説明するためのブロック図である。

本実施形態の中継回路30は、図1にて前述したごとく、2つのプロセッサ（制御回路10およびシミュレータ20）の間を繋ぐバス上に共有メモリ31をそなえて構成されている。より詳細に説明すると、中継回路30は、図16に示すように、共有メモリ31を成す複数のレジスタ31aと、第1書込／読出制御部として機能するセレクタ32と、第2書込／読出制御部として機能するセレクタ33とをそなえて構成されている。

## 【0118】

ここで、レジスタ31aは、それぞれ、制御回路10（制御ファームウェア）からシミュレータ20への制御量とシミュレータ20から制御回路10（制御ファームウェア）への状態量とを含むデータを一時的に保持しうるものである。

セレクタ32は、複数のレジスタ31aと制御回路10との間でデータの書込／読出を制御するもので、制御回路10からF／Wアドレスバス61を介して与えられたアドレス情報に応じて、複数のレジスタ31aのうちの一つ（アドレス情報に応じたレジスタ31a）とF／Wデータバス62とを接続するように切替動作を行なうものである。

## 【0119】

また、セレクタ33は、複数のレジスタ31aとシミュレータ20との間でデータの書込／読出を制御するもので、シミュレータ20からシミュレータアドレスバス71を介して与えられたアドレス情報に応じて、複数のレジスタ31aのうちの一つ（アドレス情報に応じたレジスタ31a）とシミュレータデータバス72とを接続するように切替動作を行なうものである。

## 【0120】

このような構成により、制御回路10（ファームウェア）からの制御量は、データバス62およびセレクタ32を通じ、指定されたレジスタ31aに一旦書き込まれた後、同期信号（サーボタスク信号のクリア）に応じて、セレクタ33およびデータバス72を通じシミュレータ20に入力される。一方、シミュレータ

20からの状態量は、データバス72およびセレクタ33を通じ、指定されたレジスタ31aに一旦書き込まれた後、同期信号（割込信号S V I n t）に応じて、セレクタ32およびデータバス62を通じて制御回路10に入力される。

#### 【0121】

このとき、本実施形態の中継回路30では、シミュレータ20からの割込信号S V I n tが、特定のレジスタ31a（図16では最上段のレジスタ）における所定ビットnに書き込まれ、そのビットnの値（割込信号S V I n t）が、直接外部に出力され、セレクタ32を介すことなくレジスタ31aから制御回路10へ直接的に送出されるように構成されている。

#### 【0122】

これにより、制御回路10側では、セレクタ32による読出制御（ファームウェアの読み込み動作）を行なうことなく割込信号S V I n tを得ることができ、ハードウェア割り込みを利用した同期処理を行なうことが可能になる。従って、ファームウェアのメインループにてS V I n tを常に監視するためのポーリングを行なう必要がなくなる。

#### 【0123】

なお、図16に示す中継回路30の共有メモリ31は、双方向アクセスが可能なレジスタ31aにより構成されているが、回路を簡素化するために、制御ファームウェアがライト専用で用い且つシミュレータ20がリード専用で用いるレジスタと、シミュレータ20がライト専用で用い且つ制御ファームウェアがリード専用で用いるレジスタとの二種類から構成されてもよい。さらに、レジスタ31aの一方の側だけリード／ライト可能な構成としてもよい。この場合、割込信号S V I n tは、シミュレータ20側からライト可能なレジスタ31aにおける所定ビットに書き込まれる。

#### 【0124】

ところで、本発明の目的は、ファームウェア（サーボ制御プログラム）の開発・デバッグ（検証）を支援することであるが、そのためには、制御回路10とシミュレータ20との間における通信内容を傍受したり、その通信内容を捏造したりすることができると、デバッグ時に便利である。

そこで、本実施形態では、図17～図20に示すような各種機能が中継機構30にそなえられている。

【0125】

ここで、図17は任意のレジスタ31aの内容を表示する機能をそなえた中継回路30の構成を示すブロック図、図18は特定のレジスタ31aの内容を表示する機能をそなえた中継回路30の構成を示すブロック図、図19は特定のレジスタ31aにデータを設定する機能をそなえた中継回路30の構成を示すブロック図、図20はレジスタ31aからのデータにノイズを重畳する機能をそなえた中継回路30の構成を示すブロック図である。

【0126】

図17に示す中継回路30では、複数のレジスタ31aに保持されているデータを表示しうるデータ表示用セグメント（データ表示部）36がそなえられるとともに、このセグメント36に表示すべきデータを保持するレジスタ31aを選択・指定するための、レジスタ選択スイッチ（選択部）34およびセレクタ（選択部）35がそなえられている。

【0127】

レジスタ選択スイッチ34は、例えばディップスイッチ、ロータリスイッチ等で構成されオペレータ等により手動操作されるものである。また、セレクタ35は、レジスタ選択スイッチ34からの信号に応じ、複数のレジスタ31aのうちの一つ（前記信号に応じたレジスタ31a）とセグメント36とを接続するよう切替動作を行ない、そのレジスタ31aに保持されているデータをセグメント36に表示させるものである。

【0128】

これにより、制御回路10とシミュレータ20との間で通信中のデータであって任意のレジスタ31aに保持されるデータが、オペレータ等の指示に応じてセグメント36で表示され、オペレータ等はそのデータを参照・確認することができる。

なお、ここで、回路規模を小さくするため、セレクタ35として、バス用セレクタ32もしくは33を流用し、バスの未使用時にのみ、そのセレクタ32もし

くは33を介してセグメント36にデータを表示するようにしてもよい。

【0129】

また、図17に示すごとくセグメント36でデジタル表示する他に、セレクタ35で選択されたデータを、そのままデジタル信号として出力し他のコンピュータに入力して記録したり、D/A変換器を介してアナログ出力しオシロスコープなどで表示・観察したりしてもよい。

【0130】

さらに、図18に示すごとく、スイッチ34やセレクタ35を省略し、データ表示用セグメント36aで表示するレジスタ31aを特定のものに固定してもよい。つまり、図18に示す中継回路30では、セグメント36aは、複数のレジスタ31aのうちの特定のものに直接的に接続され、その特定のレジスタ31aに保持されているデータのみをデジタル表示している。

【0131】

また、図19に示す中継回路30では、複数のレジスタ31aのうちの少なくとも一つに所望のデータを強制的に設定・格納するためのスイッチ（データ入力部）37がそなえられている。

本実施形態において、スイッチ37は、例えばディップスイッチ、ロータリスイッチ等で構成されオペレータ等により手動操作されるもので、複数のレジスタ31aのうちの特定のものに直接的に接続され、その特定のレジスタ31aに、スイッチ37によって指定されたデータが設定入力されるようになっている。このスイッチ37を接続されたレジスタ31aは、読み取り専用となっている。

【0132】

そして、このように特定のレジスタ31aに設定されたデータを、ファームウェア（あるいはシミュレータ20）で読めるようにすることにより、そのデータに応じた制御プログラムの挙動や仮想メカモデル21の動作状態を確認することができ、制御プログラムのデバッグを支援することができる。

【0133】

なお、スイッチ37からデータを手動入力する他に、外部から与えられたアナログデータをA/D変換器によりデジタルデータに変換して特定のレジスタ31

aに設定入力したり、他のコンピュータの出力であるデジタルデータを、直接、特定のレジスタ31aに設定入力したりすることで、デバッグを支援することも考えられる。

#### 【0134】

また、図19に示すような機能を用いることにより、サーボゲインの調整を手動入力によりリアルタイムで行なったり、FFT (Fast Fourier Transform) アナライザを用いて解析を行なったりすることができる。

FFTアナライザを用いる場合、FFTアナライザはアナログ信号を入出力するものであるため、FFTアナライザからの出力（アナログ信号）を、A/D変換器によりデジタル信号に変換して特定のレジスタ31aに設定し、対象物（シミュレータ20もしくはファームウェア）からの応答を待つ。そして、対象物からの応答（デジタル信号）をD/A変換器によりアナログ信号に変換してからFFTアナライザに入力することになる。

#### 【0135】

さらに、図20に示す中継回路30では、特定のレジスタ31aから読み出されたデータにスイッチ39を介してノイズを重畠する加算器（ノイズ重畠部）38a, 38bが、レジスタ31aの両側（ファームウェア側およびシミュレータ20側）のそれぞれそなえられている。

これにより、オペレータ等は、ノイズを加算器38a, 38bによってデータに重畠することができ、そのノイズに応じたファームウェア（制御プログラム）の挙動やモデルの動作状態を確認することができる。

#### 【0136】

なお、図20に示す例では、加算器38a, 38bを用いて、外部からのノイズを特定のレジスタ31a（アドレス）に加えているが、加算器38a, 38bの代わりに乗算器を用いてもよい。また、図20では、レジスタ31aの両側のバスに加算器38a, 38bをそなえているが、いずれか一方のバスのみに加算器をそなえてもよい。その他、セレクタ（図示省略）を用い任意のレジスタからの読み込み値に対してノイズを加算する機能を付加してもよい。

#### 【0137】

## 【1-9】本実施形態の効果

このように、本発明の一実施形態としての制御プログラム開発支援装置1によれば、制御回路10（MPU12）での演算処理を遅らせてシミュレータ20でのモデル演算処理（シミュレーション）と同期を取ることにより、サーボ特性を変化させずにスローモーション的に且つ時間厳密性を保ったまま、精密なシミュレーションが行なわれる。従って、実際のメカを用いることなく、比較的小型で応答の速い製品についてのサーボ制御プログラムの開発・デバッグ（検証）を行なうことができる。

## 【0138】

また、モデルパラメータを変更するだけで容易に任意の特性をもった仮想メカモデル21を作成してサーボ制御プログラム（ファームウェア）によって制御させることができるので、サーボ制御プログラムが、大量に生産される製品のバラツキにどの程度まで対応できるかの検証、つまりサーボ制御プログラムの品質検証を確実に行なうことができる。また、任意のタイミングで任意の外乱を与えることが可能なため、サーボ制御プログラムの品質をより確実に検証することができる。

## 【0139】

さらに、仮想メカモデル21を用いてシミュレーションを行なうことにより、イベントブレイクやステップデバッグなどの機能を使用することが可能になり、サーボ制御プログラム開発をより容易に行なえるほか、新しいアクチュエータやセンサを用いた新規の制御手法も簡単に検証することができる。

オペレータ等は、図5や図8で説明した同期設定手段（GUI機能）を用いることにより、シミュレータ20の動作と制御回路10（ファームウェア）の動作との同期設定を容易かつ任意に行なうことができる。

## 【0140】

図8～図10で説明したマルチレート制御手段を用いて、一制御周期中に制御量が変化するマルチレート制御がシミュレートされるので、本実施形態の制御プログラム開発支援装置1は、サーボロジックがマルチレート制御を実現していた場合に確実に対応することができる。その際、オペレータ等は、図8で説明した

マルチレート設定手段（G U I 機能）を用いることにより、そのマルチレート制御を容易かつ任意に定義・設定することができる。

【0141】

図7にて説明したように、シミュレータ20によるシミュレーション結果に応じて、サーボ制御ルーチンへ移行することができるので、タイマによるフェイルセーフ機能の確認や、単位時間当たりの変化量（速度、回転数等）を測定する処理への対応など、各種機能が実現され、サーボ制御プログラムの開発・デバッグ（検証）を確実に支援することができる。

【0142】

また、図15にて説明したように、仮想メカモデル21の構成部分の動作シミュレーションを、複数のプロセッサ（本実施形態ではMCU12a～12c）で並列的に実行することができるので、シミュレーション処理を大幅に高速化することができる。

【0143】

さらに、本実施形態では、図16～図20に示すように、中継回路30を、複数のレジスタ31a、セレクタ32および33によって構成することで、制御回路10からの制御量やシミュレータ20からの状態量を、レジスタ31aにおいて一時的に保持してから、シミュレータ20や制御回路10に確実に中継することができる。

【0144】

このとき、ファームウェア（制御回路10）側ではセレクタ32による読み出制御を行なうことなく割込信号S V I n tを得ることができるので、ハードウェア割り込みを利用した同期処理を行なうことが可能になり、制御回路10は、その割込信号S V I n tに応じて、制御量の算出動作を直ちに且つ確実に開始することができる。

【0145】

また、図17や図18に示すごとく、制御回路10とシミュレータ20との間で通信中のデータを表示するデータ表示用セグメント36、36aにより、オペレータ等はそのデータを参照・確認することができるので、サーボ制御プログラ

ムの開発・デバッグ（検証）を確実に支援することができる。

【0146】

さらに、図19に示すごとく、オペレータ等は、任意のデータを、スイッチ37からレジスタ31aに書き込むことによって制御回路10やシミュレータ20へ直接的に入力することができるので、そのデータに応じたサーボ制御プログラムの挙動や仮想メカモデル21の動作状態を確認することが可能になり、サーボ制御プログラムの開発・デバッグ（検証）を確実に支援することができる。

【0147】

そして、図20に示すごとく、オペレータ等は、ノイズを加算器38a, 38bによってデータに重畠することができるので、そのノイズに応じたサーボ制御プログラムの挙動やモデルの動作状態を確認することが可能になり、サーボ制御プログラムの開発・デバッグ（検証）を確実に支援することができる。

【0148】

〔2〕その他

なお、本発明は上述した実施形態に限定されるものではなく、本発明の趣旨を逸脱しない範囲で種々変形して実施することができる。

例えば、上述した実施形態では、制御対象が磁気ディスクドライブ（HDD）である場合について説明したが、本発明は、これに限定されるものではなく、光ディスク（CD, MO, DVD, MD）, 磁気テープ装置（DAT, VTR）, NC工作機など、緻密なサーボ制御を必要とするあらゆる分野に応用することができる。さらに、上述した実施形態では、制御対象がサーボ機構である場合について説明したが、本発明は、このようなサーボ機構に限定されるものではない。

【0149】

〔3〕付記

（付記1） 機構の動作を制御する制御プログラムを実行し、該機構に対する制御量を所定の制御周期で算出して出力する制御プログラム実行部と、

該機構を仮想的なモデルとして内部に構築され、該モデルを用い、前記所定制御周期よりも短く設定された所定のシミュレーション周期で、前記所定の制御周期に対応する時間に亘って該機構の動作をシミュレートすることにより、該機構

の状態量を算出して出力するシミュレーション部と、

該制御プログラム実行部から該シミュレーション部への前記制御量、および、該シミュレーション部から該制御プログラム実行部への前記状態量を一時的に保持し中継する中継部と、

該シミュレーション部からの前記状態量が該中継部に保持されると、該シミュレーション部を、該制御プログラム実行部からの応答待ち状態へ移行させるとともに、該制御プログラム実行部による、前記状態量に応じた制御量の算出動作を開始させる一方、該制御プログラム実行部からの前記制御量が該中継部に保持されると、該制御プログラム実行部を、該シミュレーション部からの応答待ち状態へ移行させるとともに、該シミュレーション部による、前記制御量に応じたシミュレーション動作を開始させるシミュレーション制御部とをそなえたことを特徴とする、制御プログラム開発支援装置。

#### 【0150】

(付記2) サーボ機構の動作を制御する制御プログラムを実行し、該サーボ機構に対する制御量を所定の制御周期で算出して出力する制御プログラム実行部と、

該サーボ機構を仮想的なモデルとして内部に構築され、該モデルを用いて該サーボ機構の動作を動力学的に解析しながら、前記所定制御周期よりも短く設定された所定のシミュレーション周期で、前記所定の制御周期に対応する時間に亘って該サーボ機構の動作をシミュレートすることにより、該サーボ機構の状態量を算出して出力するシミュレーション部と、

該制御プログラム実行部から該シミュレーション部への前記制御量、および、該シミュレーション部から該制御プログラム実行部への前記状態量を一時的に保持し中継する中継部と、

該シミュレーション部からの前記状態量が該中継部に保持されると、該シミュレーション部を、該制御プログラム実行部からの応答待ち状態へ移行させるとともに、該制御プログラム実行部による、前記状態量に応じた制御量の算出動作を開始させる一方、該制御プログラム実行部からの前記制御量が該中継部に保持されると、該制御プログラム実行部を、該シミュレーション部からの応答待ち状態

へ移行させるとともに、該シミュレーション部による、前記制御量に応じたシミュレーション動作を開始させるシミュレーション制御部とをそなえたことを特徴とする、制御プログラム開発支援装置。

## 【0151】

(付記3) 該シミュレーション制御部の同期設定を行なうための同期設定手段をそなえたことを特徴とする、付記2記載のサーボ制御プログラム開発支援装置。

(付記4) 該同期設定手段が、グラフィカルユーザインタフェース機能を用いて構成されていることを特徴とする、付記3記載の制御プログラム開発支援装置。

## 【0152】

(付記5) 該制御プログラム実行部が、一制御周期中において異なるタイミングで該シミュレーション部に入力されるべき複数の制御量を出力するものあり、

前記複数の制御量をそれぞれ所定のタイミングで該シミュレーション部に入力するように制御量の入力制御を行なうマルチレート制御手段をそなえたことを特徴とする、付記1記載の制御プログラム開発支援装置。

## 【0153】

(付記6) 該マルチレート制御手段の設定を行なうためのマルチレート設定手段をそなえたことを特徴とする、付記5記載の制御プログラム開発支援装置。

(付記7) 該マルチレート設定手段が、グラフィカルユーザインタフェース機能を用いて構成されていることを特徴とする、付記6記載の制御プログラム開発支援装置。

## 【0154】

(付記8) 該シミュレーション制御部が、該シミュレーション部によるシミュレーション結果に基づいて、該制御プログラム実行部による前記制御量の算出動作の開始タイミングを決定することを特徴とする、付記2記載の制御プログラム開発支援装置。

(付記9) 該モデルが、その動作のシミュレーションを個別に実行すること

が可能な複数の部分から構成されるものであり、

該シミュレーション部が、前記複数の部分それぞれの動作を並列的にシミュレートする複数のプロセッサをそなえて構成されていることを特徴とする、付記2記載の制御プログラム開発支援装置。

【0155】

(付記10) 該中継部が、

該制御プログラム実行部から該シミュレーション部への前記制御量と該シミュレーション部から該制御プログラム実行部への前記状態量とを含むデータを一時的に保持しうる複数のレジスタと、

該複数のレジスタと該制御プログラム実行部との間で前記データの書込／読み出を制御する第1書込／読み出制御部と、

該複数のレジスタと該シミュレーション部との間で前記データの書込／読み出を制御する第2書込／読み出制御部とをそなえて構成されていることを特徴とする、付記2記載の制御プログラム開発支援装置。

【0156】

(付記11) 該制御プログラム実行部による前記制御量の算出動作を開始させるべく該シミュレーション部から該複数のレジスタの一つに入力された割込信号については、該第1書込／読み出制御部を介することなく、当該レジスタから該制御プログラム実行部へ直接的に送出されることを特徴とする、請求項10記載の制御プログラム開発支援装置。

【0157】

(付記12) 該複数のレジスタに保持されているデータを表示しうるデータ表示部をそなえたことを特徴とする、付記10記載の制御プログラム開発支援装置。

(付記13) 該複数のレジスタの中から選択した、少なくとも一つのレジスタに保持されているデータを該データ表示部に表示させる選択部をそなえたことを特徴とする、付記12記載の制御プログラム開発支援装置。

【0158】

(付記14) 該データ表示部が、該複数のレジスタのうちの特定のものに直

接的に接続され、該特定のレジスタに保持されているデータを表示することを特徴とする、付記12記載の制御プログラム開発支援装置。

(付記15) 該複数のレジスタのうちの少なくとも一つに所望のデータを強制的に設定・格納するためのデータ入力部をそなえたことを特徴とする、付記10記載の制御プログラム開発支援装置。

#### 【0159】

(付記16) 該データ入力部が、該複数のレジスタのうちの特定のものに直接的に接続され、該特定のレジスタに前記所望のデータを設定することを特徴とする、付記15記載の制御プログラム開発支援装置。

(付記17) 該複数のレジスタのうちの少なくとも一つから読み出されたデータにノイズを重畠するノイズ重畠部をそなえたことを特徴とする、付記10記載の制御プログラム開発支援装置。

#### 【0160】

##### 【発明の効果】

以上詳述したように、本発明の制御プログラム開発支援装置によれば、以下のような効果ないし利点を得ることができる。

(1) 制御プログラム実行部での演算処理を遅らせてシミュレーション部でのモデル演算処理(シミュレーション)と同期を取ることにより、機構の特性(サーボ特性)を変化させずにスローモーション的に且つ時間厳密性を保ったまま、精密なシミュレーションが行なわれる。従って、実際のメカを用いることなく、比較的小型で応答の速い製品についての制御プログラムの開発・デバッグ(検証)を行なうことができる(請求項1, 2)。

#### 【0161】

(2) モデルパラメータを変更するだけで容易に任意の特性をもったモデルを作成して制御プログラムによって制御させることができる。従って、制御プログラムが、大量に生産される製品のバラツキにどの程度まで対応できるかの検証、つまり制御プログラムの品質検証を確実に行なうことができる(請求項1, 2)。

。

#### 【0162】

(3) 仮想的なモデルを用いてシミュレーションを行なうことにより、ステップデバッグなどの機能を使用することが可能になり、制御プログラム開発をより容易に行なえるほか、新しいアクチュエータやセンサを用いた新規の制御手法も簡単に検証することが可能になる（請求項1，2）。

(4) オペレータ等は、同期設定手段（G U I 機能）を用いて、シミュレーション部の動作と制御プログラム実行部の動作との同期設定を容易かつ任意に行なうことができる。

#### 【0163】

(5) マルチレート制御手段を用いて、一制御周期中に制御量が変化するマルチレート制御がシミュレートされるので、サーボロジックがマルチレート制御を実現していた場合に確実に対応することができる（請求項3）。その際、オペレータ等は、マルチレート設定手段（G U I 機能）を用いて、そのマルチレート制御を容易かつ任意に定義・設定することができる。

#### 【0164】

(6) シミュレーション部によるシミュレーション結果に応じて、制御プログラム実行部での制御ルーチンへ移行することができるので、タイマによるフェイルセーフ機能の確認や、単位時間当たりの変化量（速度、回転数等）を測定する処理への対応など、各種機能が実現され、制御プログラムの開発・デバッグ（検証）を確実に支援することができる（請求項4）。

#### 【0165】

(7) モデルの構成部分の動作シミュレーションを、複数のプロセッサで並列的に実行することができるので、シミュレーション処理を大幅に高速化することができる（請求項5）。

(8) 中継部を、複数のレジスタ、第1書き込み／読み出し制御部および第2書き込み／読み出し制御部によって構成することで、制御プログラム実行部からの制御量やシミュレーション部からの状態量を、レジスタにおいて一時的に保持してから、シミュレーション部や制御プログラム実行部に確実に中継することができる。

#### 【0166】

(9) 制御プログラム実行部側では第1書き込み／読み出し制御部による読み出し制御を行

なうことなく割込信号を得ることができるので、ハードウェア割り込みを利用した同期処理を行なうことが可能になり、制御プログラム実行部は、その割込信号に応じて、制御量の算出動作を直ちに且つ確実に開始することができる。

(10) 制御プログラム実行部とシミュレーション部との間で通信中のデータを表示するデータ表示部により、オペレータ等はそのデータを参照・確認することができるので、制御プログラムの開発・デバッグ（検証）を確実に支援することができる。

#### 【0167】

(11) オペレータ等は、任意のデータを、データ入力部からレジスタに書き込むことによって制御プログラム実行部やシミュレーション部へ直接的に入力することができるので、そのデータに応じた制御プログラムの挙動やモデルの動作状態を確認することが可能になり、制御プログラムの開発・デバッグ（検証）を確実に支援することができる。

#### 【0168】

(12) オペレータ等は、ノイズをノイズ重畠部によってデータに重畠することができるので、そのノイズに応じた制御プログラムの挙動やモデルの動作状態を確認することが可能になり、制御プログラムの開発・デバッグ（検証）を確実に支援することができる。

#### 【図面の簡単な説明】

##### 【図1】

本発明の一実施形態としての制御プログラム開発支援装置の構成を従来システムの構成と比較して示すもので、(a)は従来システムの構成を示すブロック図、(b)は本実施形態の構成を示すブロック図である。

##### 【図2】

本実施形態での同期処理手順（シミュレーション制御部の動作）を説明するためのフローチャートである。

##### 【図3】

本実施形態での同期処理手順（シミュレーション制御部の動作）を説明するためのタイムチャートである。

## 【図4】

本実施形態のシミュレータでのシミュレーション原理を説明するためのフローチャートである。

## 【図5】

本実施形態で同期設定を行なうためのモデル記述レベル（ディスプレイでの表示状態）を示す図である。

## 【図6】

図5に示すモデル記述レベルで記述・設定された同期ブロックの動作を説明するためのフローチャートである。

## 【図7】

本実施形態の装置において、割り込み間隔に応じ速度を計測する手法について説明するための図である。

## 【図8】

本実施形態で入出力の同期設定を行なうためのモデル記述レベル（ディスプレイでの表示状態）を示す図である。

## 【図9】

図8に示すモデル記述レベルで記述・設定された同期ブロックの動作を説明するためのフローチャートである。

## 【図10】

図8に示すモデル記述レベルで記述・設定された同期ブロックの動作を説明するためのタイムチャートである。

## 【図11】

本実施形態でのマルチレート制御について説明するための図である。

## 【図12】

本実施形態でマルチレート設定を行なうためのモデル記述レベル（ディスプレイでの表示状態）を示す図である。

## 【図13】

本実施形態でのマルチレート制御に先立つ初期設定手順を説明するためのフローチャートである。

【図14】

本実施形態でのマルチレート制御手順（図12に示すモデル記述レベルで設定されたマルチレートブロックの動作）を説明するためのフローチャートである。

【図15】

本実施形態でのシミュレーションの並列処理を説明するための図である。

【図16】

本実施形態の中継回路の構成および割込信号の取扱を説明するためのブロック図である。

【図17】

任意のレジスタの内容を表示する機能をそなえた中継回路の構成を示すブロック図である。

【図18】

特定のレジスタの内容を表示する機能をそなえた中継回路の構成を示すブロック図である。

【図19】

特定のレジスタにデータを設定する機能をそなえた中継回路の構成を示すブロック図である。

【図20】

レジスタからのデータにノイズを重畠する機能をそなえた中継回路の構成を示すブロック図である。

【符号の説明】

- 1 制御プログラム開発支援装置
- 1 0 制御回路（制御プログラム実行部，ファームウェア実行用プロセッサ，制御ファームウェア）
- 1 1 制御用 L S I
- 1 2, 1 2 a, 1 2 b, 1 2 c M C U (プロセッサ)
- 1 3 メモリ
- 2 0 モデル実行環境（シミュレーション部，モデル演算用プロセッサ，シミュレータ）

2 1 仮想メカモデル

2 2 シミュレーション制御部（同期処理部）

3 0 中継回路（中継部）

3 1 共有メモリ（バッファ、レジスタ）

3 1 a レジスタ

3 2 セレクタ（第1書込／読出制御部）

3 3 セレクタ（第2書込／読出制御部）

3 4 レジスタ選択スイッチ（選択部）

3 5 セレクタ（選択部）

3 6, 3 6 a データ表示用セグメント（データ表示部）

3 7 スイッチ（データ入力部）

3 8 a, 3 8 b 加算器（ノイズ重畠部）

3 9 スイッチ

4 0 状態表示記録部（データ表示部）

5 0 ディスク

5 0 a サーボマーク

5 1 ヘッド

6 1 F/Wアドレスバス

6 2 F/Wデータバス

7 1 シミュレータアドレスバス

7 2 シミュレータデータバス

1 0 0 メカ

1 1 0 アクチュエータ

1 2 0 センサ

2 0 0 制御回路

2 1 0 制御用L S I

2 1 1 C P U

2 1 2 メモリ

2 1 3 サーボロジック

214 センサロジック

220 ドライバ

230 検出回路

300 状態表示部

B2, B2' 同期ブロック (同期処理部, シミュレーション制御部)

B5 制御対象モデル

B6 マルチレートブロック (マルチレート制御手段)

【書類名】図面

【図1】



## 【図2】



【図3】



【図4】



【図5】



【図6】



【図7】



【図8】



【図9】



【図10】



【図11】



【図12】



【図13】



【図14】



【図15】



【図16】



【図17】



### 【図18】



【図19】



【図20】



【書類名】 要約書

【要約】

【課題】 実際のメカを用いることなく、比較的小型で応答の速い製品（機構）を制御するための制御プログラムの開発・デバッグを行なえるようにする。

【解決手段】 シミュレーション周期を制御周期よりも短く設定し、シミュレーション部20が、制御周期に対応する時間に亘ってシミュレーション周期でサーボ機構の動作をシミュレートし、そのシミュレーションによって得られたサーボ機構の状態量を中継回路30へ出力するとともに、シミュレーション制御部22が、状態量が中継回路30に保持されると、シミュレーション部20を応答待ち状態へ移行させるとともに制御プログラム実行部10による制御量の算出動作を開始させる一方、制御量が中継回路30に保持されると、制御プログラム実行部10を応答待ち状態へ移行させるとともにシミュレーション部20によるシミュレーション動作を開始させるように構成する。

【選択図】 図1

出願人履歴情報

識別番号 [000005223]

1. 変更年月日 1996年 3月26日

[変更理由] 住所変更

住 所 神奈川県川崎市中原区上小田中4丁目1番1号

氏 名 富士通株式会社